﻿<html DIR="LTR" xmlns:tool="http://www.microsoft.com/tooltip" xmlns:xlink="http://www.w3.org/1999/xlink" xmlns:ddue="http://ddue.schemas.microsoft.com/authoring/2003/5" xmlns:MSHelp="http://msdn.microsoft.com/mshelp">
  <head>
    <META HTTP-EQUIV="Content-Type" CONTENT="text/html; CHARSET=utf-8" />
    <META NAME="save" CONTENT="history" />
    <title>Entendendo controle de simultaneidade</title>
    
    <link rel="stylesheet" type="text/css" href="../local/Classic.css">
      
    </link>
    
    <script src="../local/script.js">
      
    </script><script src="../local/script_main.js">&amp;nbsp;</script>
  </head>
  <body>
    <!--Topic built:04/01/2010 05:03:30-->

    
    
    
    
    
    
    
    
    
    <div id="header">
      <table width="100%" id="topTable"><tr>
          <td align="left">
            <span id="headerBold">Entendendo controle de simultaneidade</span>
          </td>
          <td align="right">
            
          </td>
        </tr></table>
      
      
      
    </div>
    <div id="mainSection">
      
        
        
    <font color="DarkGray">
      
    </font>
    <p />
    
    <p />
  
        <div id="introductionSection" class="section">
    <p>O controle de simultaneidade refere-se às várias técnicas que são usadas para preservar a integridade dos bancos de dados quando vários usuários estão atualizando linhas ao mesmo tempo. A simultaneidade incorreta pode conduzir a problemas como leituras sujas, leituras de fantasma e leituras não repetíveis. O Microsoft SQL Server JDBC Driver fornece interfaces a todas as técnicas de simultaneidade usadas pelo SQL Server para resolver estes problemas. </p>
    <div style="margin: .5em 1.5em .5em 1.5em"><b>Observação: </b>
      Para obter mais informações sobre simultaneidade SQL Server, veja "Gerenciando o acesso simultâneo a dados" nos Manuais Online do SQL Server.<p />
    </div>
    <p>O driver JDBC oferece suporte aos seguintes tipos de simultaneidade:</p>
    <table width="100%" cellspacing="0" cellpadding="0" border="1" style="background-color: #CCCCCC;"><tr>
          <th>
            Tipo de simultaneidade
          </th>
          <th>
            Características
          </th>
          <th>
            Bloqueios de linha
          </th>
          <th>
            Descrição
          </th>
        </tr><tr>
        <td>
          <p>CONCUR_READ_ONLY</p>
        </td>
        <td>
          <p>Somente Leitura</p>
        </td>
        <td>
          <p>Não</p>
        </td>
        <td>
          <p>Não são permitidas atualizações pelo cursor e não é mantido nenhum bloqueio nas linhas que compõem o conjunto de resultados.</p>
        </td>
      </tr><tr>
        <td>
          <p>CONCUR_UPDATABLE</p>
        </td>
        <td>
          <p>Gravação de leitura otimista</p>
        </td>
        <td>
          <p>Não</p>
        </td>
        <td>
          <p>O banco de dados assumir contenção de linha é improvável, mas possível. A integridade de linha é verificada com uma comparação de carimbo de data e hora.</p>
        </td>
      </tr><tr>
        <td>
          <p>CONCUR_SS_SCROLL_LOCKS</p>
        </td>
        <td>
          <p>Gravação de leitura pessimista</p>
        </td>
        <td>
          <p>Sim</p>
        </td>
        <td>
          <p>O banco de dados assumir contenção de linha é provável. A integridade de linha é assegurada com bloqueio de linha.</p>
        </td>
      </tr><tr>
        <td>
          <p>CONCUR_SS_OPTIMISTIC_CC</p>
        </td>
        <td>
          <p>Gravação de leitura otimista</p>
        </td>
        <td>
          <p>Não</p>
        </td>
        <td>
          <p>O banco de dados assumir contenção de linha é improvável, mas possível. A integridade da linha é verificada com uma comparação de carimbo de data/hora. </p>
          <p>Para o SQL Server 2005 e posterior, o servidor alterará esse tipo para CONCUR_SS_OPTIMISTIC_CCVAL se a tabela não contiver uma coluna de carimbo de data/hora.</p>
          <p>Para o SQL Server 2000, se a tabela subjacente tiver uma coluna de carimbo de data e hora, OPTIMISTIC WITH ROW VERSIONING será usado mesmo se OPTIMISTIC WITH VALUES for especificado. Se OPTIMISTIC WITH ROW VERSIONING for especificado e a tabela não tiver carimbos de data e hora, OPTIMISTIC WITH VALUES será usado.</p>
        </td>
      </tr><tr>
        <td>
          <p>CONCUR_SS_OPTIMISTIC_CCVAL</p>
        </td>
        <td>
          <p>Gravação de leitura otimista</p>
        </td>
        <td>
          <p>Não</p>
        </td>
        <td>
          <p>O banco de dados assumir contenção de linha é improvável, mas possível. A integridade de linha é verificada com uma comparação de dados da linha.</p>
        </td>
      </tr></table>
  </div><h1 class="heading">Conjuntos de resultados que não são atualizáveis</h1><div id="sectionSection0" class="section"><content xmlns="http://ddue.schemas.microsoft.com/authoring/2003/5">
      <p xmlns="">Um conjunto de resultados atualizável é um conjunto de resultados no qual linhas podem ser inseridas, atualizadas e excluídas. Nos casos seguintes, o SQL Server não pode criar um cursor atualizável. A exceção gerada é "O conjunto de resultados não é atualizável". </p>
      <table width="100%" cellspacing="0" cellpadding="0" border="1" style="background-color: #CCCCCC;" xmlns=""><tr>
            <th>
              Causa
            </th>
            <th>
              Descrição
            </th>
            <th>
              Solução
            </th>
          </tr><tr>
          <td>
            <p>A instrução não é criada usando a sintaxe do JDBC 2.0 (ou posterior)</p>
          </td>
          <td>
            <p>O JDBC 2.0 introduziu novos métodos para criar instruções. Se a sintaxe do JDBC 1.0 for usada, o conjunto de resultados seguirá o padrão somente leitura.</p>
          </td>
          <td>
            <p>Especifique o tipo de conjunto de resultados e simultaneidade ao criar a instrução.</p>
          </td>
        </tr><tr>
          <td>
            <p>A instrução é criada usando TYPE_SCROLL_INSENSITIVE</p>
          </td>
          <td>
            <p>
              O SQL Server cria um cursor de instantâneo estático. Ele é desconectado das linhas de tabela subjacentes para ajudar a proteger o cursor de atualizações de linha feitas por outros usuários.</p>
          </td>
          <td>
            <p>Use TYPE_SCROLL_SENSITIVE, TYPE_SS_SCROLL_KEYSET, TYPE_SS_SCROLL_DYNAMIC ou TYPE_FORWARD_ONLY com CONCUR_UPDATABLE para evitar criar um cursor estático.</p>
          </td>
        </tr><tr>
          <td>
            <p>O design de tabela impede um cursor KEYSET ou DYNAMIC</p>
          </td>
          <td>
            <p>A tabela subjacente não tem chave exclusiva para permitir que o SQL Server identifique uma linha exclusivamente.</p>
          </td>
          <td>
            <p>Acrescente chaves exclusivas à tabela para fornecer identificação exclusiva de cada linha.</p>
          </td>
        </tr></table>
    </content></div><span id="seeAlsoSpan"><h1 class="heading">Consulte também</h1></span><div id="seeAlsoSection" class="section" name="collapseableSection"><a href="9ed5ad41-22e0-4e4a-8a79-10512db60d50.htm">Gerenciando conjuntos de resultados com o JDBC Driver</a><br /><br /></div><!--[if gte IE 5]>
			<tool:tip element="seeAlsoToolTip" avoidmouse="false"/><tool:tip element="languageFilterToolTip" avoidmouse="false"/><tool:tip element="roleInfoSpan" avoidmouse="false"/>
		<![endif]-->
      <div id="footer" class="section">
        
		<hr />
		
		<span id="fb" class="feedbackcss">
			
			
		</span>
		
		<a href="9bad553b-9e70-4696-8499-2e35f772a1e0.htm">
			
			© 2010 Microsoft Corporation. Todos os direitos reservados.
		</a>
 	
	
      </div>
    </div>
  </body>
</html>